#pragma once
#include<stdio.h>
#include<stdlib.h>
#include<stdbool.h>
#include<assert.h>

typedef int QDataType;

typedef struct QueueNode {
	QDataType val;
	struct QueueNode* next;
}QNode;

typedef struct Queue {
	QNode* phead;
	QNode* ptail;
	int size;
}Queue;

void QueueInint(Queue* ps);
void QueueDestroy(Queue* ps);

void QueuePush(Queue* ps, QDataType x);
void QueuePop(Queue* ps);

QDataType QueueFront(Queue* ps);
QDataType QueueBack(Queue* ps);

bool QueueEmpty(Queue* ps);
int Queuesize(Queue* ps);